<template>
  <div class="app-container">
    <el-form
      :model="adminInfo"
      :rules="setRules"
      ref="ruleForm"
      label-width="100px"
      width="500px"
    >
      <el-form-item label="用户名">
        <el-input
          v-model="adminInfo.name"
          placeholder="请输入用户名"
        ></el-input>
      </el-form-item>
      <el-form-item label="旧密码" prop="oldLoginPwd">
        <el-input
          v-model="adminInfo.oldLoginPwd"
          placeholder="请输入旧密码"
          type="password"
        ></el-input>
      </el-form-item>

      <el-form-item label="新密码" prop="loginPwd">
        <el-input
          v-model="adminInfo.loginPwd"
          placeholder="请输入新密码"
          type="password"
        ></el-input>
      </el-form-item>

      <el-form-item label="新密码确认" prop="loginPwdConfirm">
        <el-input
          v-model="adminInfo.loginPwdConfirm"
          placeholder="请确认新密码"
          type="password"
        ></el-input>
      </el-form-item>

      <el-button type="primary" style="margin-top: 15px" @click="handleClick"
        >修改</el-button
      >
      <el-button type="danger" style="margin-top: 15px" @click="handleBack"
        >返回</el-button
      >
    </el-form>
  </div>
</template>

<script>
import {getInfo, updateAdmin} from "@/api/user";
export default {
  data() {
    var validatePass2 = (rule, value, callback) => {
      if (value === "") {
        callback(new Error("请再次输入新密码"));
      } else if (value !== this.adminInfo.loginPwd) {
        callback(new Error("两次输入密码不一致！"));
      } else {
        callback();
      }
    };
    return {
      url: "",
      adminInfo: {
        id: "",
        loginId: "",
        name: "",
        oldLoginPwd: "",
        loginPwd: "",
        loginPwdConfirm: "",
      },
      setRules: {
        oldLoginPwd: [
          { required: true, trigger: "blur", message: "请输入旧的密码" },
        ],
        loginPwd: [
          { required: true, trigger: "blur", message: "请输入新的密码" },
        ],
        loginPwdConfirm: [
          {required: true, trigger: "blur", message: "请再次输入新密码"},
          {validator: validatePass2, trigger: "blur"}
        ]
      },
    };
  },
  created() {
    this.fetchData();
  },
  methods: {
    fetchData() {
      getInfo().then(res => {
        this.adminInfo = {...res.data};
      })
    },
    handleClick() {
      console.log(this.adminInfo)
      if(this.adminInfo.name && this.adminInfo.loginPwd && this.adminInfo.oldLoginPwd) {
        updateAdmin(this.adminInfo).then(res => {
          if(res.code === 0) {
            this.$message.success('修改成功, 请重新登录');
            this.$store.dispatch('user/logout').then(() => {
              this.$router.push(`/login?redirect=${this.$route.fullPath}`);
            })
          } else {
            this.$message.error(res.msg);
          }
        })
      } else {
        this.$message.error('请填写所有项目');
      }
    },
    handleBack() {
      this.$router.push('/');
    },
  },
};
</script>

<style>
</style>
